This chapter describes how to load GW-BASIC into your system. It also explains the two different types of operation modes, line formats, and the various elements of GW-BASIC.
To use the GW-BASIC language, you must load it into the memory of your computer from your working copy of the MS-DOS diskette. Use the following procedure:
Type the following command after the A> prompt, and press RETURN:
gwbasic
Once you enter GW-BASIC, the GW-BASIC prompt, Ok, will replace the MS-DOS prompt, A>.
On the screen, the line XXXXX Bytes Free indicates how many bytes are available for use in memory while using GW-BASIC.
The function key (F1–F10) assignments appear on the bottom line of the screen. These function keys can be used to eliminate key strokes and save you time. Chapter 4, "The GW-BASIC Screen Editor," contains detailed information on function keys.
Once GW-BASIC is initialized (loaded), it displays the Ok prompt. Ok means GW-BASIC is at command level; that is, it is ready to accept commands. At this point, GW-BASIC may be used in either of two modes: direct mode or indirect mode.
In the direct mode, GW-BASIC statements and commands are executed as they are entered. Results of arithmetic and logical operations can be displayed immediately and/or stored for later use, but the instructions themselves are lost after execution. This mode is useful for debugging and for using GW-BASIC as a calculator for quick computations that do not require a complete program.
The indirect mode is used to enter programs. Program lines are always preceded by line numbers, and are stored in memory. The program stored in memory is executed by entering the RUN command.
The GW-BASIC command line lets you change the environment or the conditions that apply while using GW-BASIC.
Note
When you specify modifications to the operating environment of GW-BASIC, be sure to maintain the parameter sequence shown in the syntax statement. To skip a parameter, insert a comma. This will let the computer know that you have no changes to that particular parameter.
GW-BASIC uses a command line of the following form:
gwbasic[filename][<stdin][[>]>stdout][/f:n][/i][/s:n][/c:n][/m:[n][,n]][/d]
filename is the name of a GW-BASIC program file. If this parameter is present, GW-BASIC proceeds as if a RUN command had been given. If no extension is provided for the filename, a default file extension of .BAS is assumed. The .BAS extension indicates that the file is a GW-BASIC file. The maximum number of characters a filename may contain is eight with a decimal and three extension characters.
<stdin redirects GW-BASIC's standard input to be read from the specified file. When used, it must appear before any switches.
This might be used when you have multiple files that might be used by your program and you wish to specify a particular input file.
>stdout redirects GW-BASIC's standard output to the specified file or device. When used, it must appear before any switches. Using >> before stdout causes output to be appended.
GW-BASIC can be redirected to read from standard input (keyboard) and write to standard output (screen) by providing the input and output filenames on the command line as follows:
gwbasic program name <input file[>]>output file
An explanation of file redirection follows this discussion of the GW-BASIC command line.
Switches appear frequently in command lines; they designate a specified course of action for the command, as opposed to using the default for that setting. A switch parameter is preceded by a slash (/).
/f:n sets the maximum number of files that may be opened simultaneously during the execution of a GW-BASIC program. Each file requires 194 bytes for the File Control Block (FCB) plus 128 bytes for the data buffer. The data buffer size may be altered with the /s: switch. If the /f: switch is omitted, the maximum number of open files defaults to 3. This switch is ignored unless the /i switch is also specified on the command line.
/i makes GW-BASIC statically allocate space required for file operations, based on the /s and /f switches.
/s:n sets the maximum record length allowed for use with files. The record length option in the OPEN statement cannot exceed this value. If the /s: switch is omitted, the record length defaults to 128 bytes. The maximum record size is 32767.
/c:n controls RS-232 communications. If RS-232 cards are present, /c:0 disables RS-232 support, and any subsequent I/O attempts for each RS-232 card present. If the /c: switch is omitted, 256 bytes are allocated for the receive buffer and 128 bytes for the transmit buffer for each card present.
The /c: switch has no affect when RS-232 cards are not present. The /c:n switch allocates n bytes for the receive buffer and 128 bytes for the transmit buffer for each RS-232 card present.
/m:n[,n] sets the highest memory location (first n) and maximum block size (second n) used by GW-BASIC. GW-BASIC attempts to allocate 64K bytes of memory for the data and stack segments. If machine language subroutines are to be used with GW-BASIC programs, use the /m: switch to set the highest location that GW-BASIC can use. The maximum block size is in multiples of 16. It is used to reserve space for user programs (assembly language subroutines) beyond GW-BASIC's workspace.
The default for maximum block size is the highest memory location. The default for the highest memory location is 64K bytes unless maximum block size is specified, in which case the default is the maximum block size (in multiples of 16).
/d allows certain functions to return double-precision results. When the /d switch is specified, approximately 3000 bytes of additional code space are used. The functions affected are ATN, COS, EXP, LOG, SIN, SQR, and TAN.
Note
All switch numbers may be specified as decimal, octal (preceded by &O), or hexadecimal (preceded by &H).
Sample GW-BASIC command lines are as follows:
The following uses 64K bytes of memory and three files; loads and executes the program file payroll.bas:
A>gwbasic PAYROLL
The following uses 64K bytes of memory and six files; loads and executes the program file invent.bas:
A>gwbasic INVENT /F:6
The following disables RS-232 support and uses only the first 32K bytes of memory. 32K bytes above that are reserved for user programs:
A>gwbasic /C:0 /M:32768,4096
The following uses four files and allows a maximum record length of 512 bytes:
A>gwbasic /F:4 /S:512
The following uses 64K bytes of memory and three files. Allocates 512 bytes to RS-232 receive buffers and 128 bytes to transmit buffers, and loads and executes the program file tty.bas:
A>gwbasic TTY /C:512
For more information about RS-232 Communications, see Appendix F.
When redirected, all INPUT, LINE INPUT, INPUT$, and INKEY$ statements are read from the specified input file instead of the keyboard.
All PRINT statements write to the specified output file instead of the screen.
Error messages go to standard output and to the screen.
File input from KYBD: is still read from the keyboard.
File output to SCRN: still outputs to the screen.
GW-BASIC continues to trap keys when the ON KEY(n) statement is used.
Typing CTRL-BREAK when output is redirected causes GW-BASIC to close any open files, issue the message "Break in line nnnn" to standard output, exit GW-BASIC, and return to MS-DOS.
When input is redirected, GW-BASIC continues to read from this source until a CTRL-Z is detected. This condition can be tested with the end-of-file (EOF) function. If the file is not terminated by a CTRL-Z, or if a GW-BASIC file input statement tries to read past the end of file, then any open files are closed, and GW-BASIC returns to MS-DOS.
For further information about these statements and other statements, functions, commands, and variables mentioned in this text, refer to the GW-BASIC User's Reference.
Some examples of redirection follow.
GWBASIC MYPROG >DATA.OUT
Data read by the INPUT and LINE INPUT statements continues to come from the keyboard. Data output by the PRINT statement goes into the data.out file.
gwbasic MYPROG <DATA.IN
Data read by the INPUT and LINE INPUT statements comes from data.in. Data output by PRINT continues to go to the screen.
gwbasic MYPROG <MYINPUT.DAT >MYOUTPUT.DAT
Data read by the INPUT and LINE INPUT statements now come from the file myinput.dat, and data output by the PRINT statements goes into myoutput.dat.
gwbasic MYPROG <\SALES\JOHN\TRANS.DAT >>\SALES\SALES.DAT
Data read by the INPUT and LINE INPUT statements now comes from the file \sales\john\trans.dat. Data output by the PRINT statement is appended to the file \sales\sales.dat.
A GW-BASIC program is made up of several elements: keywords, commands, statements, functions, and variables.
GW-BASIC keywords, such as PRINT, GOTO, and RETURN have special significance for the GW-BASIC Interpreter. GW-BASIC interprets keywords as part of statements or commands.
Keywords are also called reserved words. They cannot be used as variable names, or the system will interpret them as commands. However, keywords may be embedded within variable names.
Keywords are stored in the system as tokens (1- or 2-byte characters) for the most efficient use of memory space.
Commands and statements are both executable instructions. The difference between commands and statements is that commands are generally executed in the direct mode, or command level of the interpreter. They usually perform some type of program maintenance such as editing, loading, or saving programs. When GW-BASIC is invoked and the GW-BASIC prompt, Ok, appears, the system assumes command level.
A statement, such as ON ERROR...GOTO, is a group of GW-BASIC keywords generally used in GW-BASIC program lines as part of a program. When the program is run, statements are executed when, and as, they appear.
The GW-BASIC Interpreter performs both numeric and string functions.
The GW-BASIC Interpreter can perform certain mathematical (arithmetical or algebraic) calculations. For example, it calculates the sine (SIN), cosine (COS), or tangent (TAN) of angle x.
Unless otherwise indicated, only integer and single-precision results are returned by numeric functions.
String functions operate on strings. For example, TIME$ and DATE$ return the time and date known by the system. If the current time and date are entered during system start up, the correct time and date are given (the internal clock in the computer keeps track).
Functions can be user-defined by means of the DEF FN statement. These functions can be either string or numeric.
Certain groups of alphanumeric characters are assigned values and are called variables. When variables are built into the GW-BASIC program they provide information as they are executed.
For example, ERR defines the latest error which occurred in the program; ERL gives the location of that error. Variables can also be defined and/or redefined by the user or by program content.
All GW-BASIC commands, statements, functions, and variables are individually described in the GW-BASIC User's Reference.
Each of the elements of GW-BASIC can make up sections of a program that are called statements. These statements are very similar to sentences in English. Statements are then put together in a logical manner to create programs. The GW-BASIC User's Reference describes all of the statements available for use in GW-BASIC.
In a GW-BASIC program, lines have the following format:
nnnnn statement[statements]
nnnnn is a line number
statement is a GW-BASIC statement.
A GW-BASIC program line always begins with a line number and must contain at least one character, but no more than 255 characters. Line numbers indicate the order in which the program lines are stored in memory, and are also used as references when branching and editing. The program line ends when you press the RETURN key.
Depending on the logic of your program, there may be more than one statement on a line. If so, each must be separated by a colon (:). Each of the lines in a program should be preceded by a line number. This number may be any whole integer from 0 to 65529. It is customary to use line numbers such as 10, 20, 30, and 40, in order to leave room for any additional lines that you may wish to include later. Since the computer will run the statements in numerical order, additional lines needn't appear in consecutive order on the screen: for example, if you entered line 35 after line 60, the computer would still run line 35 after line 30 and before line 40. This technique may save your reentering an entire program in order to include one line that you have forgotten.
The width of your screen is 80 characters. If your statement exceeds this width, the cursor will wrap to the next screen line automatically. Only when you press the RETURN key will the computer acknowledge the end of the line. Resist the temptation to press RETURN as you approach the edge of the screen (or beyond). The computer will automatically wrap the line for you. You can also press CTRL-RETURN, which causes the cursor to move to the beginning of the next screen line without actually entering the line. When you press RETURN, the entire logical line is passed to GW-BASIC for storage in the program.
In GW-BASIC, any line of text that begins with a numeric character is considered a program line and is processed in one of three ways after the RETURN key is pressed:
Note
Reuse of an existing line number causes all of the information contained in the original line to be lost. Be careful when entering numbers in the indirect mode. You may erase some program lines by accident.
Before you return to MS-DOS, you must save the work you have entered under GW-BASIC, or the work will be lost.
To return to MS-DOS, type the following after the Ok prompt, and press RETURN:
system
The system returns to MS-DOS, and the A> prompt appears on your screen.